<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <!-- 1. 安装 vue-router 路由模块 -->
    <script src="https://cdn.bootcss.com/vue-router/3.1.3/vue-router.js"></script>
    <style>
        .router-link-active,.myactive{
            color: red;
            font-weight: 800;
            font-style: italic;
            font-size: 80px;
            text-decoration: underline;
        }


        .v-enter,
        .v-leave-to{
            opacity: 0;
            transform: translateX(150px);
        }

        .v-enter-active,
        .v-leave-active{
            transition: all 0.5s ease;
        }
    </style>
</head>

<body>

    <div id="app">
        <!-- <a href="#/login">登录</a> -->
        <!-- <a href="#/register">注册</a> -->

        <!-- router-link 默认渲染为一个a标签 -->
        <router-link to="/login" tag="span">登录</router-link>
        <router-link to="/register">注册</router-link>
        <!-- 这是vue-router 提供的元素，专门用来当作占位符的，将来，路由规则，匹配到的组件，就会展示到这个router-view中去 -->
        <!-- 所以：我们可以把router-view 认为是一个占位符 -->
        <transition mode="out-in">
            <router-view></router-view>  
        </transition>
        
    </div>

    <script>
        // 组件模板对象
        var login = {
            template: '<h1>登录组件</h1>'
        }

        var register = {
            template: '<h1>注册组件</h1>'
        }

        // 2. 创建一个路由对象；当导入 vue-router包后，在window全局对象中，就有了一个路由的构造函数，叫做VueRouter
        // 在new路由对象的时候，可以为构造函数，传递一个配置对象
        var routerObj = new VueRouter({
            // route // 这个配置对象中的 route表示【路由匹配规则】的意思
            routes: [  // 路由匹配规则
            // 每个路由规则，都是一个对象，这个规则对象身上，有两个必须的属性
            // 属性1是path，表示监听哪个路由链接地址；
            // 属性2是component，表示，如果路由时前面匹配到的path，则展示component属性对应的那个组件
            // 注意：component的属性值，必须是一个组件的模板对象，不能时组件的引用名称
                {path: '/login',component: login},
                {path: '/register',component: register},
                {path: '/',redirect: '/login'}
            ],
            // 自定义激活类名
            linkActiveClass: 'myactive'
        })

        var vm = new Vue({
            el: '#app',
            data: {},
            methods: {},
            router: routerObj // 将路由规则对象，注册到vm实例上，用来监听url地址的变化，然后展示对应的组件
        })
    
    </script>

</body>

</html>